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Box: PATENT APPLICATION 
Assistant Commissioner for Patents 
Washington, DC 20231 

TRANSMITTAL FOR PATENT APPLICATION 

Sir: 

Transmitted herewith for filing under 37 C.F.R. § 1.53(b) is a United States patent 
application entitled DIGITAL INTERACTIVE DELIVERY SYSTEM FOR TV/MULTIMEDIA/ 
INTERNET in the name of the following inventors: Ian K. Jones, Darren B. Swansburg, Jeff L. 
Furlong, Allan B. Cameron, David J. Alston, and Sean G. Higgins. 

Enclosed are the following: 

X_ A specification, claims, and abstract in total comprising thirty-three (33) pages. 
X Ten (1 0) sheets of drawings, 

X A joint signature Combined Declaration and Power of Attorney. 

X An Assignment conveying the invention to ImagicTV, Inc., including a Form PTO 
1595 recordation cover sheet. 

A Declaration Claiming Small Entity Status pursuant to 37 C.F.R. § 1 ,9 and § 1 .27. 

X A Certificate of Mailing by "Express Mail" certifying a filing date by use of Express 
Mail Label No. EL695575043US. 
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X Priority to International Application No. PCT/CA99/00505 filed June 3, 1999 is 
claimed under 35 USC § 365(c). 

X Priority to Provisional Application Serial No. 60/088,135 filed on June 4, 1998 is 
claimed under 35 U.S.C. § 119(e). 

A certified copy of foreign priority application Serial No. . 

An Associate Power of Attorney. 

The filing fee has been calculated as shown below. 
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X_ Form PTO-2038 submitting Credit Card Payment in the amount of $730.00 is 
enclosed to cover: 

X The $690.00 government filing fee. 

X The $40,00 recordation fee of the enclosed assignment. 

Please debit Deposit Account No. 23-3178 in the amount of $ for the 

government filing fee, 

Please debit Deposit Account No. 23-3178 in the amount of $40.00 for recordation 

of the enclosed Assignment. 

X_ The Commissioner is hereby authorized to charge payment of the following fees 
associated with this communication or credit any overpayment to Deposit Account 
No. 23-3178. 

X Any additional filing fees required under 37 C.F.R. § 1.16. 
X Any patent application processing fees under 37 C.F.R, §1.17. 
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The Commissioner is hereby authorized to charge payment of the following fees 
during the pendency of this application or credit any overpayment to Deposit 
Account No. 23-3178. 

X Any filing fees under 37 C.F.R. § LI 6 for presentation of extra claims. 
X Any patent application processing fees under 37 C.F.R. §1.17. 



X A duplicate copy of this letter is enclosed. 

Please address all fixture correspondence in connection with the above-identified patent 
application to the attention of the undersigned. 

Dated this 28 th day of September 2000. 



The issue fee set forth in 37 C.F.R. § 1.18 at or before mailing of the Notice 
of Allowance, pursuant to 37 C.F.R. § 1.311(b). 




DANA L. TANGREN 



Attorney for Applicant 
Registration No. 37,246 
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Express Mailing Label No. EL695575043US Docket No. 13587.14 

DIGITAL INTERACTIVE DELIVERY SYSTEM FOR TV/MULTIMEDIA/INTERNET 

Related Applications 

This application claims priority on the basis of U.S. provisional application No. 
5 60/088,135 filed 4 June, 1998 and is a continuation-in-part of PCT Application No. 
PCT/CA99/00505 designating the United States and filed 3 June, 1999. 

Technical Field 

The invention generally provides a computer software application for end-to-end 
10 management of the delivery of IP-configured integrated multimedia signals (e.g. TV, 
^ video, Website, etc.) to a subscriber (consumer) using multicast transmissions over a 
w [ broadband network and, in particular, provides a system and method for use by a 
In service provider (e.g. a telco) for interactive delivery of multimedia directly to a 
3 subscriber's personal computer (PC) or television/set-top box combination, 
if 

O Background 

ry TV broadcasts are currently delivered through service providers such as cable 

companies, and satellite operators and, of course, direct broadcast reception via 
^ traditional antennas and rabbit ears. Conventional cable service requires the 
20 installation of a dedicated cable to the subscriber's residence. Satellite broadcast 

service requires that the user have a satellite dish located on or somewhere close to 
their residence. Antennas and rabbit ears are generally limited to the reception of local 
programming. 

25 It is well known that the purchase of personal computers by homeowners has 

increased dramatically in recent years. Typically, these computers are used for word 
processing, accounting and other record keeping purposes. Most of these computers 
also have modems for connection to the Internet through an Internet Service Provider 
(ISP) utilizing conventional telephone service. Frequently, however, these modems 

30 have a low baud rate that makes downloading of information, particularly graphics, 
unacceptable. 
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To date, the provision of multimedia/television services has relied on the use of 
set-top boxes or PC's with added hardware devices such as TV tuner cards to convert 
signals from cable, satellite and DSL television systems which are configured for 
display on a television. Often TV viewers in a home may wish to watch programming in 
5 different rooms. The cost of additional set-tops and or television devices in a home can 
be prohibitive. Adding hardware to a PC to seek set-top like functionality is both costly 
and difficult for the average consumer to perform. 

There is, therefore, a need in the marketplace for means to allow service 
1QL providers to offer an alternative to cable and satellite TV as presently known. 

Further, there is a need for a system that overcomes the foregoing problems so 
iO as to enable usage of an ordinary PC and monitor to receive and display broadcast 
,=p multimedia/television signals. Note that such PC's already exist in many consumer's 
if* homes and are often underutilized as compared to the televisions in those homes. 
^ Additionally, there is a need by broadcast providers to expand the types of receiver 
JU devices available in the marketplace so that multimedia/television broadcasts may be 

targeted outside of the traditional home location and instead to active PC users who 
S may be located anywhere (or may even be roaming) and thereby greatly broaden 
20 access to broadcast content. 

Summary of the Invention 

The present invention enables the provision of subscription multimedia/ 
television/Internet services over managed broadband networks and provides an 
25 interactive client (subscriber) device component, such as in the form of a PC-based 
software component interface, that enables a PC to receive, select and process 
multimedia/television/internet signals for display on the PC monitor. 

In accordance with the invention there is provided a management system and 
30 method for managing the delivery of multimedia broadcast signals from a broadcast 
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provider to a subscriber and providing to the subscriber interactive access to the 
signals, the broadcast signals being configured according to IP (Internet Protocol) 
format for multicast transmission over a broadband network and reception by a 
subscriber device. An interactive program guide (IPG) component is configured for 
providing to the subscriber an interactive program guide (IPG) permitting selection of 
the multimedia signals by the subscriber. A subscriber device component associated 
with the subscriber device is configured for receiving instructions from the subscriber. 
The subscriber device may comprise a set top box and a television coupled thereto, the 
set top box comprising a decoder configured for converting the selected IP multicast 
format signals into a display format for display on the television, or a computer and a 
computer monitor coupled thereto, the computer comprising a decoder configured for 
converting said IP multicast format signals into a display format for display on the 
monitor. The subscriber device comprises a subscriber input interface (e.g. 
keyboard/mouse) coupled thereto for receiving instructions from the subscriber. 

The subscriber device component associated with the subscriber's computer 
includes a PC component configured for displaying the converted multimedia signals on 
the monitor in the form of a player window. The PC component is preferably configured 
for displaying a remote controller GUI on the monitor, with the remote controller GUI 
being controllable by the subscriber through the subscriber input interface for controlling 
the selection of the multimedia signals from the IPG. Preferably, the remote controller 
GUI is a model of a hand-held remote controller. 

Preferably, the interactive program guide provides a drop down box selection 
and scroll bar GUI features and program schedule cells associated with a channel 
lineup listing selectable television broadcast channels. The channel lineup may include 
one or more channels corresponding to selectable URLs. 



Significantly, all of these features are delivered via IP and ATM technologies 



using a single point of access rather than a combination of delivery systems such as 
satellite and cable. 

Brief Description of the Drawings 
5 The present invention will now be described in greater detail with reference to the 

following drawings in which like reference numerals refer to like elements throughout. 

Figure 1 is a block diagram of a preferred multimedia broadcast delivery system 
in accordance with the invention (hereinafter referred to as the "delivery system"); 
Figure 2 is a further block diagram of the delivery system; 
10 Figure 3 is a schematic block diagram of the elements of the delivery system and 

y3 the operational components of the system manager component 40 (hereinafter referred 
Zl to as the "system manager"); 

*0 Figure 4 is a schematic operational diagram of the delivery system and system 

£ manager; 

15^ Figure 5 is a schematic diagram illustrating a layered relationship of the 

C3 components of the delivery system and system manager; 
ru Figure 6 is an exemplary interactive program guide (IPG) generated by the 

}J; system manager for display by a television through a set-top box; 
O Figure 7 is another exemplary interactive program guide (IPG) generated by the 

20 system manager for display by a personal computer (PC); 

Figure 8 is an exemplary player window and virtual remote control generated by 
the system manager for display by a personal computer (PC); 

Figure 9 is an exemplary virtual remote controller, showing the basic functions 
available, as generated by the system manager for display by a personal computer 
25 (PC); 

Figure 10 is the virtual remote controller of Figure 10 but showing the "options" 
box selected and the various available optional functions displayed; and, 

Figure 1 1 illustrates a system for concurrent transmission of MPEG-1 and 
MPEG-2 encoded signals. 
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Detailed Description of a Preferred Embodiment 

Figure 1 is a high-level block diagram of the basic elements of an exemplary 
multimedia delivery system as contemplated herein; for the convenience of the reader a 
glossary of several terms used herein, setting out their well-known meaning in the 
5 communications art, is provided herein as Appendix A. 

At the head-end 24 of the system a video source 12 retrieves multimedia/ 
television/Internet signals for broadcast from various sources such as satellites in the 
form of MPEG-compliant, Multi-Program Transport Streams (MPTS) and these signals 
10_ are delivered to (analog-to-digital) video encoders 14 or (digital-to-digital) transcoders 
y3 130 where they are converted to one or more IP Multicast Single-Program Transport 
Jy Streams (SPTS). The encoder 14 encodes analog video and audio inputs. The 
j£! transcoder 130 decodes digital video and audio signals, perhaps high-speed MPEG 
JE video SPTS or MPTS, and re-encodes them into a format which is suitable for the 
15* subscriber device being STB 22 or PC 30. Each IP multicast SPTS is a packetized 
C MPEG stream which is subsequently sent out over a broadcast provider network 16 to 
a Digital Subscriber Line Access Multiplexer (DSLAM 18) 18 which might be located in a 
telephone company central office. The DSLAM 18 serves two purposes: firstly, it 
S connects broadband lines in the transport network to xDSL lines in the access network 
20 and, secondly, it separates high-speed data from voice data, putting high speed data 
on the data network and low speed data on the conventional phone system. This 
allows concurrent use of the telephone and the system manager components on the 
same phone line. An IP Multicast signal from the DSLAM 18 is delivered to a 
subscriber's residence over an xDSL link such as an Asymmetric Digital Subscriber Line 
25 (ADSL), where it is received by an ADSL modem 20 and delivered to a client server 
such as a set top box (STB) 22 or a PC 30. More precisely, xDSL lines connect the 
DSLAM 18 to an ethernet interface on the xDSL modem, and a 10BaseT cable 
connects the ethernet interface on the xDSL modem to an ethernet interface card on 
the set-top or PC. 
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The delivery system comprises software for enabling a service provider to offer 
broadcast television over Internet Protocol (IP), including IP multicast and unicast, 
which allows channel browsing by selecting and retrieving IP multicast streams. IP 
multicast is characterized by the sending out of data to distributed servers on a 
multicast backbone network. For large amounts of data (including video transmissions), 
IP multicast is more efficient than normal Internet unicast transmissions because the 
server can broadcast a message to many recipients simultaneously. Unlike traditional 
Internet traffic that requires separate connections for each source-destination pair, IP 
multicasting allows many recipients to share the same source. This means that just one 
set of packets is required to be transmitted for all the destinations. 

If the bit rate of the satellite transmission is not greater than 1 MBPS the signal 
may be transcoded directly to IP multicast MPEG. This takes existing digital 
transmissions from a satellite and reprocesses them for delivery on an IP Multicast 
delivery system. The advantages of this are that it lowers the cost of head-end 
equipment 24 (satellite dish, etc.) by replacing the encoder 14 with a transcoder 130, 
and it also maximizes the quality of the signal being delivered from a digital signal 
source at the head-end (since it is only digitized once, and remains that way). At the 
broadcast provider location a split/distributed head-end (signal from satellite) can also 
be employed to optimize transport facility cost. As shown in Figure 2, the video source 
may be a satellite located at head-end 24, which may be operated by a broadcast 
provider such as a telephone company or other service provider. The head end 24, and 
a system server complex 40, interface with a broadband network 26 through an IP 
multicast router 28 and a transport router 42, respectively. 

Digital video equipment gathers, processes, and distributes video. This 
equipment can include satellite dishes, satellite receiver units, encoders, remultiplexers, 
video servers, and IP gateways. Encoders and remultiplexers process live video, and 
video servers support the distribution of stored video. Encoders and remultiplexers 
perform two main functions: firstly, they convert individual MPEG-compliant, Multi- 



Program Transport Streams (MPTS) from satellite into one or more IP multicast Single 
Program Transport Streams (SPTS) in real time and, secondly, they multicast the IP 
SPTS's over the service provider's IP network. 

The server complex of the management system 40 (also referred to herein as the 
"system manager", "DTVM" or "Digital TV Manager") contains vital software components 
and comprises two main servers, namely, a system manager (DTVM) server and a 
database server. The DTVM server incorporates standard web server software, and 
other standard software, such as JVM (Java Virtual Machine), DHCP/BootP, RPC, and 
NFS. The database server runs standard database software and stores all data for 
consumers (such as IPG data) including events data. 

The broadband network is IP Multicast compatible and has sufficient bandwidth 
capacity to transport encoded video signals. A subscriber to the broadcast service has 
access to the network via a broadband link. Examples of broadband links include 
Digital Subscriber Line (xDSL) (such as Asymmetric Digital Subscriber Line (ADSL)) 
Asynchronous Transfer Mode (ATM), Frame Relay, Synchronous Optical Network 
(SONET), Local Multipoint Distribution System (LMDS), Hybrid Fiber Coax (HFC), or 
Fiber To The Home (FTTH). xDSL is of particular significance because it allows a 
broadcast provider to deliver programming to residential communities over existing 
copper wire (i.e. the twisted pairs linking the customer premises to the 
telecommunications network) without having to delay introduction of the service until the 
other access technologies become widely available. 

The subscriber can access the TV broadcast with either a personal computer 
(PC) 30 having an associated monitor or a television 32 with a set top box (STB) 22 
such that, in essence, the STBs and PC's act as network computers. Each PC and 
STB is configured from downloaded multicasted data sources and uses a head-end 
server for persistent storage. Accordingly, the consumer access 20 operates out of 
memory (RAM) rather than a hard disk and this means that there is no dependence at 
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the consumer end on moving parts and this, in turn, provides improved performance, 
decreased costs, reduced noise and fewer equipment failures and facilitates automatic 
software upgrades. Dependence on servers at the consumer-end is minimized and 
servers are not required for regular television viewing or Web browsing. Once an STP 
or PC boots up, basic television viewing depends only on the availability of the video 
source and the associated network. 

The set top box 22 includes decoding circuitry for decoding MPEG-1 and/or 
MPEG-2 as well as IP Multicast. To view the broadcast from a PC 30 it is equipped with 
appropriate software and may optionally be equipped with an associated MPEG card. 
The STB 22 is activated by an interface unit such as a keyboard or remote device 23 
and the PC 30 interfaces the subscriber via a keyboard and/or mouse. 

As shown in Figures 1 and 2 the broadcast provider is able to access television 
broadcast signals from various sources such as satellite 12, off-air broadcast or a static 
source such as a storage medium containing movies or the like. The service provider 
encodes the broadcast signal (MPEG) and makes it available to service subscribers (i.e. 
consumer users of the delivery system) through the broadband network 26 using the 
Internet protocol (IP). The system manager 40 is linked to the network 26 via a 
transport router 42 and provides end-to-end management of services and resources 
provided by the integrated broadcast delivery system. 

Figure 3 shows the architectural configuration of the delivery system including 
the consumer end appliances (PC and/or STB), the broadband IP network and the 
DTVM components. Figure 3 also shows another aspect of the deliverable services, i.e. 
Internet access 56. User access to the network is through an xDSL access element 
such as an ADSL Transmission Unit (ATU) 20. The broadband IP network and services 
section includes access router 28 and the transport network 'cloud 1 26. The transport 
network 26 has access to various components running parallel to the head-end, 
namely, video-on-demand (VOD) 50 and near video-on-demand (NVOD) 52, and the 
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following additional "on-demand" applications: virtual digital video recorder (VDVR) 90 
90? T "timeless" TV application and TV-on-demand, as well as e-mail 54 and Web 
access through the Internet 56. 



5 For standard broadcast signals and pay-per-view (PPV) or near video on 

demand (NVOD) services a multicast IP protocol is used in order to make efficient use 
of bandwidth. With this protocol numerous subscribers can have access to a program 
at the same time. For true video-on-demand service (VOD, VDVR, timelessTV and TV- 
on-Demand), however, a unicast IP protocol is used. The DTVM software application 40 
10 provides several features to a subscriber of the delivery and manager systems. These 
Ji include but are not limited to customer profile management 68, billing and reporting 84, 
fl Interactive Program Guide (IPG) access 60, connection and channel packaging 104 
In including a self-service option 71 , channel blocking (not shown), on-line multilingual 
J support (not shown) and information banner functions 64. 
150 

O Figure 4 is an operational schematic diagram of the broadcast delivery system. 

Jr[ The Digital Subscriber Line Access Multiplexer (DSLAM 18) 18 at the edge of the high 
CO speed IP network is a network device which may be located at a telephone company 
O central office. The DSLAM 18 enables a telephone company to provide subscribers 
20 with xDSL, such as ADSL, technology and to connect the subscriber to a fast backbone 
such as an ATM transport network 26. The ATM network routes the various broadcast 
services, previously mentioned, to the DSLAM 18 which, in turn, makes them accessible 
to subscribers via their PC 30 and/or STB 22. Figure 5 shows in a layer format the 
relationship between suppliers of the various components of the overall TV broadcast 
25 delivery system. At the bottom layer (layer 1 ) are the equipment and appliance 

suppliers such as set top box and computer suppliers, etc. The second layer (layer 2) 
represents the service provider such as a Telco who make available the IP and other 
protocols necessary to transport the video and furnish the manager application 
functions between the service provider and subscriber. The third layer (layer 3) 
30 includes the application functionality of the DTVM. As indicated in Figure 5, these 
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include consumer 80 and administration 82 service components, reporting and billing 
components 84 and IPG 65 and browser 75 components. 

The system manager (DTVM) utilizes some standards-based components and its 
5 components can be categorized into two groups, namely, client (subscriber) and server 
components. Client components run locally on the STB or PC and are collectively 
referred to herein as subscriber device components. They provide three capabilities: 
firstly, they provide viewing capability based on a user profile; secondly, they provide 
business rules based on a user profile that specify permissions and restrictions to 
10 resources; and, thirdly, they forward events and registration information to the server. 
;^ Registration information includes, among other things, the IP address of each device. 
CP Server components generate, manage, and update the data that is sent to the STB or 
III PC. Server components also organize data according to a user profile. The DTVM 
^ may run on a Sun Solaris platform (this currently being a preferred platform) but the 
15,o platform used will be dictated by the service provider based on its needs. 

^ The subscriber device component of this embodiment uses four components that 

fo are installed the STB or PC, namely, an MPEG player, a browser, a networking API and 
J5 a windowing API. The MPEG player supports video viewing and the browser supports 
20 Web browsing. The networking API supports the protocols used by the DTVM 

applications such as IP, NFS, and MPEG. The windowing API specifies what interface 
screens can be drawn and how. Within the DTVM software there are many 
components which perform the following functions: management of the display of all 
content (including MPEG video, Interactive Program Guide (IPG), and web pages), 
25 processing of remote control commands, providing time measurement ability, sending 
of events data to the server, listening for updates from the server in the IP multicast 
stream, prompting the user for registration input, sending retrieved data to the server for 
further processing, and registering STB or PC with the DTVM/service provider. An 
SNMP Management Information Base (MIB) component is also provided in each STB 
30 or PC which, conventionally, uses SNMP to query and reset remote indicators (i.e. 

10 



receives and responds to SNMP compliant messages) and, unconventionally, uses 
SNMP to update consumer specific data on client devices for purposes of remote 
diagnostics, notification of new data availability and reminders or news items. 

Several "off the shelf server components are used by the system manager and 
they play the following roles: 

• A Web server stores servlets that support administration (provisioning, remote 
diagnostics, etc.) and self service (pay-per-view, channel blocking, etc.) transactions 
and standard products such as the Netscape™ Enterprise Server and Apache™ are 
used in this. 

• JDBC (Java™ Database Connectivity) and SQL*NET™ are used to enable the Java 
applications of the DTVM to access the database. 

• A database stores all data for consumers, the IPG, events, etc., and the persistence 
architecture of the DTVM is able to support multiple database models, including 
Oracle™ and SyQuest™. 

• The operating system layer provides BootP/DHCP and NFS components to support 
set top box boot up and profile retrieval. 

The DTVM server components are written in the Java™ programming language 
and their roles are as follows: 

• DTVM uses two daemons (i.e. automated background processing modules): multicast 
and Remote Procedure Call ('RPC'). The multicast daemon broadcasts multicast data 
content to specific multicast addresses to deliver data to the STB or PC. The RPC 
daemon forwards events data and registration information from the STB or PC to the 
database server. The RPC daemon also has an RMI (Remote Method Invocation) 
interface to support distributed Java applications. Both daemons use the Sun™ native 
JVM (Java Virtual Machine). 

• Batch transactions automate the IPG update process. The IPG update process 
consists of three phases: in phase one a retrieval process uses FTP to retrieve a data 
file from the data provider that contains television programming data, in phase two a 
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mapping process maps the data file to the database and in phase three a preparation 
process formats and forwards the IPG data to the multicast server. 

• Servlets may be used to generate HTML pages that support service administration 
and self service transactions and also to invoke persistence architecture components in 
order to make changes to the database. Alternatively, JSP (Java Servlet Pages) and 
applets may be used (instead of servlets) if increased configurability and interactivity of 
self-service screens is desired. 

• Persistence architecture components facilitate connections and exchanges between 
Java business objects and database tables. 

The subscriber accesses the IPG through components in the STB 22 or PC 30. 
Some memory may be available locally for storing specific information, or alternatively, 
the entire IPG may be maintained in the network. The subscriber uses the remote 
control or keyboard/mouse 23 for interfacing with the IPG displayed on the television or 
computer monitor the interactive nature of the IPG gives a subscriber control over many 
aspects of the broadcast system. Program scheduling information may be presented in 
a form as shown in Figures 6 and 7 (Figure 6 showing a STB IPG and Figure 7 showing 
a PC IPG). With this listing displayed on a TV monitor or computer display the user can 
scan the channel line-up 126 and program schedule cells 123 listed on the display, 
choose, highlight and then click on a desired program and the television or computer 
will then automatically retrieve the selected IP multicast stream. In addition, as 
indicated in Figures 6 and 7, another clicking configuration may display a brief 
information banner 121 with relevant data concerning program content and timing for a 
highlighted selection (i.e. "Travel with Beth" in Figure 6 and "Debbie Travis' Painted 
House" in Figure 7). Additionally, a user can click on a desired program and select it for 
recording (i.e. utilizing the VDVR application). The DTVM in conjunction with the IPG 
provides a subscriber with the ability to channel browse for TV programs and/or Web 
sites and order pay-per-view programs. In the preferred embodiment a seven day 
channel lineup with scheduled automatic refresh is provided. The IPG client software is 
automatically updated by the system at regular intervals. The data provider must 
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provide programming data in a pipe delimited text file once every 24 hours, or such 
other period as may be appropriate. The DTVM system transfers data from the text file 
into the service provider's database and then multicasts IPG data from the service 
provider's database across the network to the user on the PC display or television. 

In the PC environment, as shown by Figure 7, the IPG information is displayed 
on the PC's monitor for programs that are currently in progress as well as future 
scheduled programs. Using a keyboard or mouse, the consumer is able to: use a 
seven-day schedule for available channels; by browsing the IPG window, change the 
day by selecting another day from the Scheduled Day controller! 24 which is operative 
as a drop down control ; quickly access other times in the current day by a Quick 
Access controller 125; obtain the details, in the form of a Show Block 127 and an 
Information Block 121 , for a show when it's clicked; retrieve the IP multicast stream 
corresponding to the selected channel when a Program Schedule cell 123 is double 
clicked (or the <Enter> key is pressed) if the show is currently running. The Scheduled 
Day controller 124 is a list box giving the consumer the possibility to select the day 
he/she is interested to browse. When the IPG window is activated, the current day is 
displayed. All future dates are shown as the day of the week followed by the calendar 
month and day of month. The Quick Access controller 125 is also a list box providing 
an easy and fast access to a specific daytime. A cell of the Channel Lineup 126 column 
contains the station call letters and channel number for the station that is broadcasting 
the listed programs. On operation of the IPG the top station of the channel lineup is 
the channel currently playing unless no station is playing in which case the top one is 
the first available. 

The data associated with the Program Schedule Cells 123 is controlled according 
to the following. When the IPG window is activated, the 7 day IPG data is already 
prepared and stored in the local memory of the PC (the client device). The system 
selects the IPG data of the selected day beginning with the current time and displays it 
in the IPG window. When another day is selected by the Scheduled Day controller 124, 
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the corresponding data is selected and displayed again. These cells contain the show 
title and represent the area the consumer may browse through to view the one day 
program schedule or select a program that is currently being broadcast on a station. 
When a highlighted program is currently in progress the consumer may select that 
5 program by double clicking (or by pressing the <Enter> key) the program cell 123. The 
cells 123 are displayed with corners marking the start and end times. 

A program cell 123 can be selected through three different processes as follows: 
1) The user can use the mouse to click a cell and the cell will then be the selected cell; 
10 2) The user can scroll using the keyboard arrow keys and each arrow key press will 
^ select the cell the user is navigating to; or, 3) When the system timer adds a minute to 
y i the local clock and the first cell on the grid then becomes in the past, the new first cell in 
in that row will become the selected cell. If the selected cell is not in view when automatic 
l: | scrolling takes place, nothing will change, but the system will display the appropriate 
153 selected cell when it comes into view. Similarly, three different processes are provided 
□ for changing the viewable contents of the program cells grid: 1 ) The user may use the 
J arrow keys to navigate and as the selected cell meets a boundary, the grid 
£0 automatically scrolls if there is more information in the desired direction; 2) The user 
g may click the scroll bars 120 and as long as there is information in the direction the user 
20 is scrolling, the grid will scroll; or, 3) If the system clock updates and visible cells 
become in the past, the grid will automatically scroll. 

The IPG functionality as described above is identical to that of the TV/set-top box 
environment but without the PC's windows-based features including the ability to 
25 minimize/resize the IPG window, the scroll bars 120 and the drop down list box 

functionality provided by the Scheduled Day controller 124 and Quick Access controller 
125. In addition, the PC's user-input mouse clicks would be substituted with STB 
remote controller clicks. 

30 When the IPG component is invoked (i.e. by clicking on the IPG icon 109 or on 
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the Remote Controller's IPG button) the system manager retrieves the correct current 
date and time for the consumer's time zone, corrects all the shows times according to 
the consumer's time zone, selects the IPG data for the whole current day beginning with 
the current time, assigns the selected data to the IPG window's components and 
activates the IPG window. 

As stated above the IPG is a software application that operates in, for example, 
both a windows and set-top environment and provides a link to a client 
MPEG-1/MPEG-2 decoder and a client conditional access module. This software also 
provides the user with access to all broadcast content on the broadband multicast IP 
network as well as supporting services (i.e. subscription management). The IPG data 
delivery software component 60 is server software which provides the broadcast 
content schedules to the IPG client component software 65 based on the broadcast 
provider, customer location and customer profile. The server software 60 operates to 
extract broadcast content schedules from various existing data sources. 

A banner server 64 is server software which provides scheduled ad insertion into 
the IPG based on certain criteria such as the time of day, the broadcast provider, the 
customer location and the customer profile. A near video-on-demand (NVOD) server 
66 provides scheduled managed delivery of pre-recorded material via an IP multicast 
network. A customer profile management system/subscription management software 
component 68 stores and tracks customer preferences, usage patterns, billing status, 
mailing addresses, client devices, service subscription, etc. It also provides the core 
data for many of the other components of the system manager (DTVM). A notifier and 
indicator software component 70 enables the system to script, send and display on the 
customer's television/set top box or computer display notices and messages such as 
notifications regarding service changes or regarding broadcast scheduling changes 
affecting programs which have been scheduled for recording, promotional features, 
telephone message caller ID and recorded messages. 



15 



The IPG may also provide access to VOD, NVOD, VDVR, Timeless TV and TV- 
on-demand, Internet programming and video and audio content. "VOD" is an umbrella 
term referring to technologies that enable individuals to select a video (e.g. movie) from 
a static array of pre-recorded multimedia choices provided from a central server for 
viewing on a television or computer screen. The on-line applications enable individuals 
to select program content stored in a dynamic array of recorded video broadcasts 
provided from a central server for viewing on a television or a computer screen. The 
multimedia selection could, similarly, provide for games-on-demand whereby 
Nintendo™-type games may be made available for access by subscribers through the 
IPG. Alternatively, a Web user interface may be provided for selection of a game 
whereby subscribers are charged per game/time played. 

The on-demand VDVR software server 100 provides the user access to video 
playback using interactive DVR controls for optimal control. It includes tools for storing, 
managing and delivering real-time, full-screen video and audio content. In addition to 
tools for recording, storing, managing and delivering full screen video and audio 
content, it utilizes the core components of the system manager, including, but not 
limited to, Customer Profile Management 68, Interactive Program Guide 65, Consumer 
Self-Service 71, Operational Services 88, Multilingual Support (not shown), and 
Channel Packaging 104. 

A conditional access system (not shown) consists of both a source and 
destination software component and is responsible for the encryption, as desired, of 
data between the source and destination to protect against unauthorized use or 
copying. 

A consumer services application 80 enables and controls connection services, 
self-ordering services and provisioning. An automatic service function of the consumer 
services application 80 eliminates the need for the service provider (e.g. Telco service 
trucks) to go to the consumer's location to add or remove new channel offerings. 
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Instead, the subscriber is provided the means to change channel/package information 
online. Consumer profiles are updated immediately to the consumer's STB or PC by 
way of IP Multicast and/or SNMP. This eliminates any need for equipment and/or 
personnel's physical presence to be dispatched to the user's home to connect or 
disconnect the appropriate channels. An administration services application 82 
handles, inter alia, the importation of IPG data on a scheduled basis. Channel 
packaging, which enables a user to manage the user's subscription (including self- 
service), is provided by a user interface module 71 and enables the user to view, add 
and delete channels from the user's service subscription. A report and billing software 
application 84 provides integrated billing and reporting which enables a user 
(subscriber) to dynamically monitor service usage, keep track of service costs on a self- 
serve basis and pay bills. A user is able to utilize this ability to monitor the household's 
viewing history to determine, for example, the amount of television being viewed by 
children and whether the programs watched are suitable. A database software 
component 86 provides an information database of broadcast content unique to the 
broadcast distribution system provider to feed the IPG database. An operational 
services component 88 of the system manager integrates the control of all the 
broadcast delivery system components into a networked management framework and 
provides quality management functions and collects usage information. 

Additionally, the DTVM enables remote management of the user appliances 
including the ability to query and reset key indicators such as system health indicators 
(e.g. MPEG diagnosis), application and network status (e.g. current viewed channel, 
current NFS server), and to re-initialize a user device. This may be accomplished by, 
for example, an SNMP protocol. The DTVM also remotely informs the user, to the 
user's set top box or computer display, that new data and/or software is available and 
should be retrieved. This may be accomplished by, for example, IP multicast and/or 
SNMP. 

The broadcast delivery system may also provide to the service provider an option 
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of assigning URL's to channel numbers. A URL is an address used to enable an 
Internet browser program to find a particular Internet resource, for example, 
'http://www.imagictv.com'. Using this feature a subscriber could view a URL channel on 
the IPG similar to a television or video channel. Subscribers are then able to scan 
through URL channels and select a desired URL by entering the associated numbers 
from the remote device in the same way as television or video channels are selected. 
Going through a URL channel would switch the user device (e.g. the set top box or PC) 
to a web browser and thereby access a selected web page. The broadcast delivery 
system may also provide for channel hotlinks such that while watching a program, or 
when a program is highlighted on the IPG, the user can operate a remote entry device 
to activate a transfer to a dynamic web page. Such web page could display, for 
example, information on the program, on the channel, or on the subject matter currently 
being shown. 

The DTVM software enables a subscriber to personalize channel selection, for 
example, create a list of favourite programs which the user can scan on the IPG and 
select from or have the television/set top box (or computer) automatically switch to at 
designated times. In addition, a one touch search feature may be provided to enable a 
user to specify certain searching criteria, such as program theme, by actor, by 
program/movie title, etc, and initiate one step searching to retrieve requested 
programming information from the IPG. Similarly, the user may be provided with the 
ability to view a program's video trailer from the interactive program guide when the user 
"clicks on'Vselects that program. The DTVM software may also provide an intelligent 
agent which may be set up to remind a user of an upcoming program, or recommend 
program content based on user criteria, provide gathered data from outside source such 
as TV Guide, movie critics, etc. 

Other features provided by the DTVM include Multicast download where 
information required to boot a network device to a multicast group is constantly 
delivered by a network server. The DHCP server is configured to return the multicast 



18 



address and port as parameters in a BOOTP response. The network device is 
programmed to join the multicast group and download a bootstrap program to local 
memory and boot from the local memory rather than across the network. Also, the 
system can provide a multicast file system wherein a server constantly delivers a read- 
only file system to a multicast group. A network device is programmed to access the file 
system by joining the multicast group and waiting until the requested file appears. 
Encryption is used for security and compression is used to minimize bandwidth. Since 
multicast UDP may lose packets, the multicast group is rejoined and holes in the files 
are filled if holes exist. 

For the PC user, the DTVM includes a PC component for installation in the PC 
which, advantageously, allows the user to watch television programming on a PC using 
the normal PC hardware and without requiring special hardware such as a TV tuner 
card. The PC component utilizes the core components of the DTVM such as Report 
and Billing Services 84 (including Integrated Reporting, Integrated Billing, and Service 
Administration), Administrative Services 82 (including IPG Data Import, Channel 
Packaging and Service Administration), Consumer Services 80 (including Connect 
Services, Consumer Self-Service and Provisioning), the Interactive Program Guide 
Client (including NVOD, Live Mpeg, Notifiers and Indicators, Profile, IPG Data Delivery 
and a Banner Service), the Browser Client (including Email, the World Wide Web, VOD, 
the On-Demand products, and Self-Ordering) and the Operational Services 88 
(including Event Export, Event Collection and Network Management). On the client 
side, the PC component provides all of its functionality in software. 

The PC component is itself comprised of three main components: a player 
window component, a virtual remote control component and an IPG component. The 
player window component provides a resizable viewing window 112, as illustrated by 
Figure 8, containing three selectable objects: a channel selector 108 , a program guide 
icon 109 , and a remote control icon 110. The channel selector 108 is a pull down 
window that enables the user to select and retrieve an IP multicast stream 
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corresponding to a specific channel. When the remote control icon 1 10 is selected a 
virtual remote controller 1 14 (being a window-type GUI) is opened and displayed as 
illustrated in Figure 8. When the program guide icon is selected an IPG as shown by 
Figure 7 appears as a separate contollable window. 

The PC component is navigated by the user using traditional windows-based 
click functions on drop down lists, together with the virtual remote control. The remote 
control design is such that, for user comfort, it represents a virtual model of the known 
physical hand-held remote controllers. The virtual remote controller 114, showing the 
basic functions available, is illustrated in Figure 9. Figure 10 shows the "options" box 
selected for the virtual controller 1 14 and the various optional functions which are 
available to the user are displayed below the "options" button. As shown by Figures 9 
and 10 the virtual remote controller 1 14 includes user-selectable features for channel up 
131, channel down 132, volume control 133, power off 134, Guide (i.e. go to IPG) 135 
plus an expandable options feature 136 providing "preferences" 137 (viz. which directs 
the system manager to always hide the remote controller on start-up or to display the 
remote contoller to the left, to the right or always on top of the player window), TV Off 
138 (which directs the system manager to turn off the player window but to continue to 
run the system manager), Hide Remote 139 (which directs the system manager to close 
the virtual remote controller display) and About 140 which provides particulars of the 
version of the system manager application which is being run. The DTVM's Interactive 
Program Guide is interactive and allows users to scroll up, down, forward or back 
through several days of programming. A further optional function which can be 
provided by the PC component is to enable the subscriber to store a received program 
in the hard drive of the PC whereby the PC would emulate a Personal Digital Recording 
device. 

The PC component is made available to the user through downloading of 
software from a Web-based self-service component 71 . The download software 
includes a Java Runtime Environment and Java Media Framework (being executables 



20 



which are required by the PC component) and a PC setup program module. Once 
installed the PC component retrieves the IP address of the Application Server, the 
default language and the help desk registration number from the local config file 
downloaded during the install process. It then establishes a connection to the 
Application Server and retrieves the system data from a Registry file. It also retrieves 
the IP addresses and ports of the IPG data and IPG related data from the database. To 
retrieve IPG related data the PC periodically joins the IP Multicast group for the IPG 
related data for the specified IP address and port, waits for the beginning of the stream 
and downloads the IPG data until the end of the stream and then extracts and stores 
the program information for existing stations including schedule information on its local 
drive. The delivery system searches the server for the consumer file to confirm the 
consumer has subscribed to the service and retrieves the consumer specific information 
from the consumer file including any custom profiles the user may have created. 

Channel selection for the PC component is identical to that for the STB in that 
when the user selects a channel from the channel lineup, the system checks for the 
source type of the channel and, ilf it's video/audio, it gets the IP multicast address and 
port of the selected channel from the IPG Related Data object and 'tunes' into the 
channel by joining the multicast address, thereby retrieving the signal from the transport 
network rather than, as in conventional tuning systems, tuning into one of several 
signals broadcast into the home. If the source is a Web channel, the system clears the 
player window, gets the homepage URL associated with the channel, and launches the 
default browser for the already retrieved URL. In the home, subscribers select a 
channel number on the virtual remote controller. This triggers the PC component to 
issue an IGMP (Internet Group Management Protocol) request to join the corresponding 
IP multicast address. That is, the channel entry triggers the PC component to 'tune into' 
the IP multicast address where the channel can be found. To service the request, an 
IGMP-enabled network router sends channel data to the PC. Completing the process, 
the PC decodes the packetized MPEG stream into video and audio for display on the 
PC monitor. 
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Optionally, as shown by Figure 1 1 , concurrent transmission of each channel via 
both MPEG-1 and MPEG-2 may be provided to allow fall back when access bandwidth 
becomes impaired. This, in effect, provides a backup system if failure occurs on the 
main transmission facility. Use of such a back-up system, based on a configurable 
algorithm, enables the system manager to recognize that there has been a failure to 
deliver a video signal and, on doing so, to switch to an alternate signal. This increases 
the level of broadcast availability in the event of a loop (e.g. xDSL) impairment, encoder 
failure, or facility/network failure. This also allows for multiple client devices (STBs 
and/or PCs) in a single home to negotiate for the best available signal. 

The terms algorithm, module and component herein are used interchangeably 
and refer to any set of computer-readable instructions or commands such as in the form 
of software, without limitation to any specific location or means of operation of the 
same. The terms subscriber, consumer and customer are also used interchangeably 
herein to refer to PC/STB user of the broadcast delivery system. 

It is to be understood that the specific elements of the events capturing system 
and method described herein are not intended to limit the invention defined by the 
appended claims. From the teachings provided herein the invention could be 
implemented and embodied in any number of alternative computer program 
embodiments by persons skilled in the art without departing from the claimed invention. 
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APPENDIX A -Glossary 



BootP Refers to Bootstrap Protocol which is an Internet protocol that enables a diskless 
workstation to discover its own IP address, the IP address of a BOOTP server on the 
5 network, and a file to be loaded into memory to boot the machine. This enables the 
workstation to boot without requiring a hard or floppy disk drive. 

Daemon A process that runs in the background and performs a specified operation at 
predefined times or in response to certain events. The term daemon is a UNIX term, 
10 though many other operating systems provide support for daemons. 

2 Data Provider For the subject matter herein described, a company that provides 

Nl detailed information about television programs, including station information, show titles, 

Cg scheduled air times, etc. 

15;| 

- DHCP Dynamic Host Configuration Protocol. A protocol for assigning dynamic IP 
5 addresses to devices on a network. With dynamic addressing, a device can have a 
V* different IP address every time it connects to the network. In some systems, the 
Q device's IP address can even change while it is still connected. DHCP also supports a 
20 " mix of static and dynamic IP addresses. Dynamic addressing simplifies network 

administration because the software keeps track of IP addresses rather than requiring 
an administrator to manage the task. This means that a new computer can be added to 
a network without the hassle of manually assigning it a unique IP address. Many ISPs 
use dynamic IP addressing for dial-up users. 

25 

Domain A group of computers and devices on a network that are administered as a unit 
with common rules and procedures. Within the Internet, domains are defined by the 
Internet Protocol (IP) address. All devices sharing a common part of the IP address are 
said to be in the same domain. 

30 
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DNS Domain Name System. An Internet service that translates domain names into IP 
addresses. For example, a DNS server might translate the domain name 
"www.example.com" into the IP address 198.105.232.4. 

DSLAM Digital Subscriber Line Access Multiplexer. A technology that concentrates 
traffic in xDSL implementations through a process of TDM (time division multiplexing) at 
the Telco's central office (CO) or remote line shelf. 

HTTP Hypertext Transfer Protocol. The underlying protocol used by the World Wide 
Web. HTTP defines how messages are formatted and transmitted, and what actions 
Web servers and browsers should take in response to various commands. For example, 
when you enter a URL in your browser, this actually sends an HTTP command to the 
Web server directing it to fetch and transmit the requested Web page. 

IGMP Internet Group Management Protocol. Defined in RFC 1 1 12 as the Internet 
standard for IP multicasting. IGMP establishes host memberships in particular multicast 
groups on a single network. The mechanisms of the protocol allow a host to inform its 
local router, using Host Membership Reports, that it wants to receive messages 
addressed to a specific multicast group. All hosts conforming to level 2 of the IP 
multicasting specification require IGMP. 

IP address An identifier for a computer or device on a TCP/IP network. Networks that 
use the TCP/IP protocol route messages based on the IP address of the destination. 
The format of an IP address is a 32-bit numeric address written as four numbers 
separated by periods. Each number can be zero to 255. For example, 1. 160.10.240 
can be an IP address. 

IP Multicast Sending out data to distributed servers on the MBone (Multicast 
Backbone). For large amounts of data, IP Multicast is more efficient than normal 
Internet transmissions because the server can broadcast a message to many recipients 
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simultaneously. Unlike traditional Internet traffic that requires separate connections for 
each source - destination pair, IP Multicasting allows many recipients to share the same 
source. This means that just one set of packets is transmitted for all the destinations. 

JDBC Java Database Connectivity. A Java API (Application Interface) that enables 
Java programs to execute SQL statements. This allows Java programs to interact with 
any SQL-compliant database. Since nearly all relational database management 
systems support SQL, and because Java itself runs on most platforms, JDBC makes it 
possible to write a single database application that can run on different platforms and 
interact with different database management systems. 

Macrovision An anti-taping process that protects original material from video piracy. 
For example, a viewer cannot record a pay-per-view movie if Macrovision protection is 
in place. 

MAC address Media Access Control address. A hardware address that uniquely 
identifies each node of a network. In IEEE 802 networks, the Data Link Control (DLC) 
layer of the OSI Reference Model is divided into two sublayers: the Logical Link Control 
(LLC) layer and the Media Access Control (MAC) layer. The MAC layer interfaces 
directly with the network media. Consequently, each different type of network media 
requires a different MAC layer. 

MIB Management Information Base. A database of objects that a network 
management system can monitor. SNMP uses a standardized MIB format that allows 
any SNMP tool to monitor any device defined by a MIB. 

MPEG Moving Picture Experts Group. A family of digital video compression standards 
and file formats. MPEG generally produces better-quality video than competing 
formats, such as Video for Windows, Indeo and QuickTime. MPEG files can be 
decoded by special hardware or by software. MPEG achieves a high compression rate 
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by storing only the changes from one frame to another, instead of each entire frame. 
The video information is then encoded using a technique called DCT. MPEG uses a 
type of lossy compression, since some data is removed but the diminishment of data is 
generally imperceptible to the human eye. There are two major MPEG standards: 
5 MPEG-I and MPEG-2. Common implementations of the MPEG- 1 standard provide a 
video resolution of 352-by-240 at 30 frames per second (fps). This produces video 
quality slightly below the quality of conventional VCR videos. A newer standard, MPEG- 
2, offers resolutions of 720x480 and 1280x720 at 60 fps, with full CD-quality audio. 
This is sufficient for all the major TV standards, including NTSC, and even HDTV. 
10 MPEG-2 is used by DVD-ROMs. MPEG-2 can compress a two hour video into a few 
gigabytes. Suggested reading: MPEG Video Compression Standard, ISBN 0-412- 
i 08771 -5; and, Digital Video: An Introduction To MPEG-2, ISBN 0-412-0841 1-2. 

NAT Network Address Translation. An Internet standard that enables a local-area 
15J3 network (LAN) to use one set of IP addresses for internal traffic and a second set of 
f*2 addresses for external traffic. A NAT box located where the LAN meets the Internet 
^ makes all necessary IP address translations. NATs serve two main purposes: They 
£0 provide a type of firewall by hiding internal IP addresses and they enable a company to 
use more internal IP addresses. Since they're only used internally, there's no possibility 
20 of conflict with IP addresses used by other companies and organizations. 

NFS Network File System. An open architecture operating system designed by Sun 
Microsystems that allows all network users to access shared files stored on computers 
of different types. NFS provides access to shared files through an interface called the 

25 Virtual File System (VFS) that runs on top of TCP/IP. Users can manipulate shared 
files as if they were stored locally on the user's own hard disk. With NFS, computers 
connected to a network operate as clients while accessing remote files, and as servers 
while providing remote users access to local shared files. The NFS standards are 
publicly available and widely used. Because the set-top box referenced herein has no 

30 internal hard drive, it remotely accesses an NFS server to load its operating system, 
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software, and preferences. 



PDU Protocol Data Unit. An OSI (Open Systems interconnection) term that means 
5 "packet". A PDU is a data object exchanged by protocol machines (entities) within a 
given layer. PDUs consist of both data and control (protocol) information that allows the 
two to coordinate their interactions. 

RFC Request for Comment. A series of notes about the TCP/IP standards, procedures, 
10 and specifications. Anyone can submit an RFC. Eventually, if it gains enough interest, 
2 it may evolve into an Internet standard. Each RFC is designated by an RFC number. 

in RMI Remote Method Invocation. A set of protocols being developed by Sun's JavaSoft 
'jz division that enables Java objects to communicate remotely with other Java objects. 

O RPC Remote procedure call. A type of protocol that allows a program on one computer 

ry to execute a program on a server computer. Using RPC, a system developer need not 

::!f develop specific procedures for the server. The client program sends a message to the 

O server with appropriate arguments and the server returns a message containing the 

20 results of the program executed. 

Servlet An applet that runs on a server. The term usually refers to a Java applet that 
runs within a web server environment. This is analogous to a Java applet that runs 
within a Web browser environment. Java servlets are becoming increasingly popular as 
25 an alternative to CGI programs. The biggest difference between the two is that a Java 
applet is persistent. This means that once it is started, it stays in memory and can fulfill 
multiple requests. In contrast, a CGI program disappears once it has fulfilled a request. 
The persistence of Java applets makes them faster because there's no wasted time in 
setting up and tearing down the process. 

30 
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SNMP Simple Network Management Protocol. A set of protocols for managing complex 
networks. SNMP works by sending messages, called protocol data units (PDUs), to 
different parts of a network. SNMP-compliant devices, called agents, store data about 
themselves in Management Information Bases (MIBs) and return this data to the SNMP 
5 requesters. 

Time Division Multiplexing A technique for transmitting a number of separate data, 
voice and/or video signals simultaneously over one communications medium by quickly 
interleaving a piece of each signal one after another. 

*Q TCP/IP Transmission Control Protocol/Internet Protocol. The suite of communications 
protocols used to connect hosts on the Internet. TCP/IP uses several protocols, the two 
2 main ones being TCP and IP. TCP/IP is built into the UNIX operating system and is 
*p used by the Internet, making it the de facto standard for transmitting data over 
15'" networks. 



ry UDP User Datagram Protocol. A connectionless protocol that, like TCP, runs on top of 
S IP networks. Unlike TCP/IP UDP/IP provides very few error recovery services, offering 
O instead a direct way to send and receive datagrams over an IP network. It's used 
20 primarily for broadcasting messages over a network. The system manager described 
herein uses the UDP protocol for the RPC server and this was chosen instead of TCP 
because TCP allows a limited number of set-top box connections through the RPC 
server. If the RPC server went down, the set-top boxes could not reconnect. 

25 URL Universal Resource Locator. An address format used by a Web browser for 
locating an Internet resource. 

xDSL x Digital Subscriber Line. Generic term for all types of digital subscriber lines, 
including ADSL (Asymmetrical DSL) and VDSL (Very-high-data-rate DSL). DSL 
30 technologies use complex modulation schemes to pack data onto copper wires. They 
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are sometimes referred to as last-mile technologies because they are used only for 
connections from a telephone switching station to a home or office, not between 
switching stations. xDSL is similar to ISDN inasmuch as both operate over existing 
copper telephone lines (POTS) and both require short runs to a central telephone office, 
usually less than 20,000 feet. However, xDSL offers much higher speeds - up to 32 
Mbps for downstream traffic, and from 32 Kbps to over I Mbps for upstream traffic. 
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What is claimed is: 




A management system for managing the delivery of multimedia broadcast 



signals from a broadcast provider to a subscriber and providing to said subscriber 
5 interactive access to said signals, said broadcast signals being configured according to 
IP (Internet Protocol) format for multicast transmission over a broadband network and 
reception by a subscriber device, said management system comprising an interactive 
program guide (IPG) component configured for providing to said subscriber an 
interactive program guide (IPG) permitting selection of said multimedia signals by said 
10 subscriber and a subscriber device component associated with said subscriber device 
and configured for receiving instructions from said subscriber. 

* ! 2. A system according to claim 1 wherein said subscriber device comprises a 
a set top box and a television coupled thereto, said set top box comprising a decoder 
152 configured for converting said selected IP multicast format signals into a display format 
%y for display on said television. 

m 3. A system according to claim 1 wherein said subscriber device comprises a 
^ computer and a computer monitor coupled thereto, said computer comprising a decoder 
20 o configured for converting said IP multicast format signals into a display format for 
display on said monitor. 

4. A system according to claim 3 wherein said subscriber device comprises a 
subscriber input interface coupled thereto for receiving instructions from said 

25 subscriber. 

5. A system according to claim 4 wherein said subscriber device component 
comprises a PC component configured for displaying said converted multimedia signals 
on said monitor in the form of a player window. 
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6. A system according to claim 5 wherein said PC component is configured for 
displaying a remote controller GUI on said monitor, said remote controller GUI being 
controllable by said subscriber through said subscriber input interface for controlling the 
selection of said signals from said IPG. 

7. A system according to claim 6 wherein said subscriber input interface comprises 
a keyboard, a mouse or a keyboard and a mouse. 

8. A system according to claim 7 wherein said interactive program guide provides 
drop down box selection and scroll bar GUI features . 

9. A system according to claim 8 wherein said remote controller GUI is a model of a 
hand-held remote controller. 

10. A system according to claim 9 wherein said IPG comprises program schedule 
cells associated with a channel lineup listing selectable television broadcast channels. 

11. A system according to claim 1 0 wherein said channel lineup includes one or 
more channels corresponding to selectable URLs. 

[2. A method for managing the delivery of multimedia broadcast signals from a 
broadcast provider to a subscriber's personal computer (PC) and providing to said 
subscriber interactive access to said signals, said broadcast signals being configured 
according to IP (Internet Protocol) format for multicast transmission over a broadband 
network and reception by said subscriber's PC, said method comprising providing to 
said subscriber an interactive program guide (IPG) permitting selection of said 
multimedia signals by said subscriber, receiving instructions from said subscriber, 
selecting a multimedia signal from said multicast transmission according to said 
received instructions and reformatting said selected signal for display on a monitor 
coupled to said subscriber's PC. 
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13. A method according to claim 12 whereby said selected signal is displayed on 
said monitor in the form of a player window. 

14. A method according to claim 13 and further comprising displaying a remote 
controller GUI on said monitor, said remote controller GUI being controllable by said 
subscriber for controlling the selection of said signals from said IPG. 

15. A method according to claim 14 whereby said interactive program guide provides 
drop down box selection and scroll bar GUI features . 

16. A method according to claim 15 whereby said remote controller GUI is a model 
of a hand-held remote controller. 

17. A method according to claim 16 wherein said IPG comprises program schedule 
cells associated with a channel lineup listing selectable television broadcast channels. 

18. A method according to claim 17 wherein said channel lineup includes one or 
more channels corresponding to selectable URLs. 
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ABSTRACT 



A computer software application for end-to-end management of the delivery of 
IP-configured integrated multimedia signals (e.g. TV, video, Website, etc.), on an 
interactive basis, to a subscriber device (being a personal computer (PC) and monitor 
coupled thereto or television/set-top box combination). The system manager 
comprises an interactive program guide (IPG) component configured for providing to the 
subscriber an interactive program guide (IPG) permitting selection of the multimedia 
signals by the subscriber and a subscriber device component associated with the 
subscriber device and configured for receiving instructions from the subscriber. The 
subscriber device includes a decoder configured for converting the selected IP multicast 
format signals into a format for display on PC monitor or television. A PC component is 
configured for displaying the converted multimedia signals on the PC monitor in the 
form of a player window and for displaying a remote controller GUI on the monitor, the 
remote controller GUI being a model of a hand-held remote controller and controllable 
by the subscriber for controlling the selection of signals from the IPG. The interactive 
program guide provides drop down box selection and scroll bar GUI features. 
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COMBINED DECLARATION and POWER OF ATTORNEY 

(Utility, Design, National Stage of PCT) 



As a below named inventor, I hereby declare that: 

TYPE OF DECLARATION 

This declaration is of the following type: 

(Check one applicable item below) 

[x] utility patent application 
[ ] design patent application 
[ ] national stage of PCT patent application 

INVENTORSHIP IDENTIFICATION 

My residence, post office address and citizenship are as stated below, next to my name. I 
believe that I am the original, first and sole inventor {if only one name is listed below) or an original, 
first and joint inventor {if plural names are listed below) of the subject matter that is claimed, and for 
which a patent is sought on the invention entitled: 

TITLE OF INVENTION 2 

DIGITAL INTERACTIVE DELIVERY SYSTEM FOR TV/MULTIMEDIA/INTERNET 

SPECIFICATION IDENTIFICATION 

the specification of which: 

{complete (a), (b), or (c)) 

(a) [x] is attached hereto. 

(b) [ ] was previously filed , as United States Patent Application Serial 

No. . 

(c) [ ] was described and claimed in PCT International Application No. filed 

on and as amended under PCT Article 19 on 

Of my)- 
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DATE OF FILING 
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38,219; ERIC L. MASCHOFF, Registration No. 36,596; C. J. VEVERKA, Registration No. 40,858; 
ROBYN L. PHILLIPS, Registration No. 39,330; RICHARD C. GILMORE, Registration No. 
37,335; DAVID B. DELLENBACH, Registration No. 39,166; KEVIN K. JOHANSON, Registration 
No. 38,506; DAVID L. GRIFFIN, Registration No. 44,136; R. BURNS ISRAELSEN, Registration 
No. 42,685; DAVID R. TODD, Registration No. 41,348; FRASER D. ROY, Registration 
No. 45,666; CARL T. REED, Registration No. 45,454; JESUS JUANOS i TIMONEDA, 
Registration No. 43,332; STEPHEN D. PRODNUK, Registration No. 43,020; R. PARRISH 
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ADRIAN J. LEE, Registration No. 42,785; KYLE H. FLINDT, Registration No. 42,539; and ERIC 
M. KAMERATH, Registration No. 46,081, with offices at WORKMAN, NYDEGGER & SEELEY, 
1000 Eagle Gate Tower, 60 East South Temple, Salt Lake City, UT 841 1 1 and Telephone (801) 533- 
9800, with full power of substitution and revocation, to prosecute said application, to make 
alterations and amendments therein, to receive the Letters Patent, and to transact all business in the 
Patent and Trademark Office connected therewith. 

All correspondence and telephone communications should be directed to: 

DANA L. TANGREN 
WORKMAN, NYDEGGER & SEELEY 
1000 Eagle Gate Tower 
60 East South Temple 
Salt Lake City, Utah 84111 
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Facsimile (801) 328-1707 
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